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(57) Abstract 



A search and recommendation system employs the preferences and 
profiles of individual users and groups within a community of users, as 
well as information derived from shared document bookmarks, to augment 
Internet searches, re-rank search results, and provide recommendations for 
documents based on a subject-matter query. The search and recommendation 
system operates in the context of a shared bookmark manager, which stores 
individual users' bookmarks (some of which may be published or shared for 
group use) on a centralized bookmark database connected to the Internet. The 
shared bookmark manager is implemented as a distributed program, portions 
of which operate on users' terminals and other portions of which operate on 
the centralized bookmark database. 
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WO 00/67159 PCT/US00/12042 

SYSTEM AND METHOD FOR SEARCHING AND RECOMMENDING 
DOCUMENTS IN A COLLECTION USING SHARED BOOKMARKS 



FIELD OF THE INVENTION 

5 The invention relates to the field of information searching and browsing, and more 

particularly to a system and method for enhancing searches and recommending documents 
in a collection through the use of bookmarks shared among a community of users. 

BACKGROUND OF THE INVENTION 

10 Computer users are increasingly finding navigating document collections to be 

difficult because of the increasing size of such collections. For example, the World Wide 
Web on the Internet includes millions of individual pages. Moreover, large companies' 
internal Intranets often include repositories filled with many thousands of documents. 

It is frequently true that the documents on the Web and in Intranet repositories are 

15 not very well indexed. Consequently, finding desired information in such a large 
collection, unless the identity, location, or characteristics of a specific document are^well 
known, can be much like looking for a needle in a haystack. 

The World Wide Web is a loosely interlinked collection of documents (mostly text 
and images) located on servers distributed over the Internet. Generally speaking, each 

20 document has an address, or Uniform Resource Locator (URL), in the exemplary form 
"http://www.server.net/directory/file.html". In that notation, the "http:" specifies the 
protocol by which the document is to be delivered, in this case the "HyperText Transport 
Protocol." The ww.server.net" specifies the name of a computer, or server, on which 
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the document resides; "director/' refers to a directory or folder on the server in which the 
document resides; and "file.html" specifies the name of the file. 

Most documents on the Web are in HTML (HyperText Markup Language) format, 
which allows for formatting to be applied to the document, external content (such as 
5 images and other multimedia data types) to be introduced within the document, and 
"hotlinks" or "'links" to other documents to be placed within the document, among other 
things. "Hotlinking" allows a user to navigate between documents on the Web simply by 
selecting an item of interest within a page. For example, a Web page about reprographic 
technology might have a hotlink to the Xerox corporate web site. By selecting the hotlink 
10 (often by clicking a marked word, image, or area with a pointing device, such as a mouse), 
the user's Web browser is instructed to follow the hotlink (usually via a URL, frequently 
invisible to the user, associated with the hotlink) and read a different document. 

Obviously, a user cannot be expected to remember a URL for each and every 
document on the Internet, or even those documents in a smaller collection of preferred 
15 documents. Accordingly, navigation assistance is not only helpful, but necessary. 

Modern Web browsers (software applications used to view and navigate 
documents on the Web) have introduced the concept of "bookmarks" or "favorites" 
(collectively referred to as "bookmarks" in this document). Bookmarks allow a user to 
identify which documents he would like to keep track of. The user's local machine then 
20 keeps track of the URLs for those sites, allowing the user to reload and view the sites' 
contents at any desired time. Bookmarks can be thought of as 4t pointers" to content on 
the Web, each specifying an address that identifies the location of the desired document, 
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but not including the document's content (except, perhaps, in a descriptive title of the 
document). 

In current versions of Netscape Navigator (specifically, at least versions 3.x and 
4.x), a user's bookmarks are stored and maintained in a special HTML file stored on the 
user's local machine. This file includes a list of sites represented as title and URL pairs (in 
a user-defined hierarchy, if desired). The user's entire set of bookmarks is contained 
within a single HTML file. 

Recent versions of Microsoft's Internet Explorer (at least versions 3.x-5.x) store 
user bookmarks (or "favorites," using Microsoft's preferred terminology) as individual 
files on the local machine's file system. Each favorite is a small file containing the site's 
URL, while the favorite's title is stored as the filename. 

Other browsers' bookmarks are frequently stored as entries in a custom 
configuration file, in which each site's title is paired with a URL. 

None of the foregoing browsers permit much sophisticated user of a user's 
collection of bookmarks, although some limited manipulations are possible. For example, 
it is usually possible to create and modify a hierarchy of bookmarks (including sorting and 
moving existing bookmarks around within the hierarchy); to modify the titles paired with 
the URLs, to search for words within the titles or URLs; and often to derive some 
additional information about the bookmarks, such as the date and time of the user's most- 
recent visit to the site, the collected number of visits, and possibly other information. 

In typical use, the bookmark facilities of Web browsers act as a "filter" for those 
documents a particular user finds to be important or usefuL While a user might view 
hundreds of Web pages in a day, only a few of those are typically found to provide useful 
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information. If that information is expected to be useful again in the future, the user will , 
often set a bookmark for those pages. This is a useful way for users to be able to access 
the Internet; however, traditional bookmarks have the distinct limitation that they are only 
useful to the extent a user has seen the sites before, since adding a bookmark to a 
5 collection is a manual act, typically performed when either the desired page is already 
being viewed or a URL has been manually received from another person. 

Most notably, the known traditional bookmark systems are single-user. Of course 
(particularly with Netscape Navigator, in which bookmarks already exist in an HTML 
file), bookmarks can be exported to a public web page, allowing others to view and use 

10 the bookmarks, but that in itself does not provide any additional functionality. 

Accordingly, when a user desires to find information on the Internet (or other large 
network) that is not already represented in the user's bookmark collection, the user will 
frequently turn to a "search engine" to locate the information. A search engine serves as 
an index into the content stored on the Internet 

15 There are two primary categories of search engines: those that include documents 

and Web sites that are analyzed and used to populate a hierarchy of subject-matter 
categories (e.g., Yahoo), and those that "crawl" the Web or document collections to build 
a searchable database of terms, allowing keyword searches on page content (such as 
AltaVista, Excite, and Infoseek, among many others). 

20 Also known are recommendation systems, which are capable of providing Web site 

recommendations based on criteria provided by a user or by comparison to a single 
preferred document (e.g.. Firefly, Excite's "more like this" feature). 
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"Google" (www.google.com) is an example of a search engine that incorporates 
several recommendation-system- like features. It operates in a similar manner to traditional 
keyword-based search engines, in that a search begins by the user's entry of one or more 
search terms used in a pattern- matching analysis of documents on the Web. It differs from 
5 traditional keyword-based search engines (such as AltaVista), in that search results are 
ranked based on a metric of page "importance," which differs from the number of 
occurrences of the desired search terms (and simple variations upon that theme). 

Google's metric of importance is based upon two primary factors: the number of 
pages (elsewhere on the Web) that link to a page (Le., 'inlinks," defining the retrieved 
10 page as an "authority 5 '), and the number of pages that the retrieved page links to (Le., 
"outlinks," defining the retrieved page as a "hub"). A page's inlinks and outlinks are 
weighted, based on the Google-determined importance of the linked pages, resulting in an 
importance score for each retrieved page. The search results are presented in order of 
decreasing score, with the most important pages presented first. It should be noted that 
15 Google's page importance metric is based on the pattern of links on the Web as a whole, 
and is not limited (and at this time cannot be limited) to the preferences of a single user or 
group of users. 

Another recent non-traditional search engine is IBM's CLEVER (CLient-side 
Eigenvector Enhanced Retrieval) system. CLEVER, like Google, operates like a 
20 traditional search engine, and uses inlinks/authorities and outlinks/hubs as metrics of page 
importance. Again, importance (based on links throughout the Web) is used to rank 
search results. Unlike Google, CLEVER uses page content (e.g., the words surrounding 
inlinks and outlinks) to attempt to classify a page's subject matter. Also, CLEVER does 
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not use its own database of Web content; rather, it uses an external hub, such as an, index . 
built by another search engine, to define initial communities of documents on the Web. 
From hubs on the Web that frequently represent people's interests, CLEVER is able to 
identify communities, and from those communities, identify related or important pages. 
5 Direct Hit is a service that cooperates with traditional search engines (such as 

HotBot), attempting to determine which pages returned in a batch of results are interesting 
or important, as perceived by users who have previously performed similar searches. 
Direct Hit tracks which pages in a list of search results are accessed most frequently; it is 
also able to track the amount of time users spend at the linked sites before returning to the 
10 search results. The most popular sites are promoted (Le., given higher scores) for future 
searches. 

Alexa is a system that is capable of tracking a user's actions while browsing. By 
doing so, Alexa maintains a database of users' browsing histories. Page importance is 
derived from other users' browsing histories. Accordingly, at any point (not just in the 

15 context of a search), Alexa can provide a user with information on related pages, derived 
from overall traffic patterns, link structures, page content, and editorial suggestions. 

Knowledge Pump, a Xerox system, provides community-based recommendations 
by initially allowing users to identify their interests and "experts" in the areas of those 
interests. Knowledge Pump is then able to "push" relevant information to the users based 

20 on those preferences; this is accomplished by monitoring network traffic to create profiles 
of users, including their interests and "communities of practice," thereby refining the 
community specifications. However, Knowledge Pump does not presently perform any 
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..enhanced search and retrieval actions like the search-engine-based systems described 
above. 

While the foregoing systems and services blend traditional search engine and 
recommendation system capabilities to some degree, it. should be recognized that none of 
5 them are presently adaptable to provide search-engine- like capabilities while taking into 
account the preferences of a smaller group than the Internet as a whole. In particular, it 
would be beneficial to be able to incorporate community-based recommendations into a 
system that is capable of retrieving previously unknown documents from the Internet. 



10 SUMMARY OF THE INVENTION 

The present system and method facilitate searching and recommending resources, 
or documents, based upon a collection of user document preferences shared by a large 
group of users. The invention leverages several of the key properties of document 
collections: only valuable documents are bookmarked; documents are usually categorized 

15 into a hierarchy; and documents can be shared. In a preferred embodiment, the present 
system combines some attributes of bookmark systems, as discussed above, with some 
attributes of search engines and recommendation systems, also discussed above. 

The present system and method maintain a centralized database of bookmarks or 
user document preferences. This centralized database is maintained as a hierarchy, with 

20 individual users' bookmarks maintained separately from other users' bookmarks. 
However, the maintenance of the centralized database facilitates harnessing the power and 
flexibility of being able to use, in various ways, all users' public bookmarks and the 
information contained in and referenced by those bookmarks. 
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The system and method of the present invention allows for several operations^ be 
performed, including enhanced search and retrieval enhanced subject-matter-based 
recommendation generation (for both documents and groups), and automatic document 
categorization and summarization. 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIGURE 1 is a block diagram illustrating the physical aspects of the invention, 
namely several users in communication with the Internet; 

FIGURE 2 is a representation of the user interface presented by the main 
bookmark window of a system according to the invention; 

FIGURE 3 is an alternate view of the user interface of FIGURE 2, in which the 
command entry listbox is expanded to show several available: commands for the system; 

FIGURE 4 is a representation of the user interface presented by a search results 
window of a system according to the invention; 

FIGURE 5 is a representation of the user interface presented by an "Add New 
Bookmark" window of a system according to the invention; 

FIGURE 6 is a representation of the user interface presented by a bookmark 
editing window of a system according to the invention; 

FIGURE 7 is a representative schematic diagram illustrating the relationships 
among all possible users of a system according to the invention, groups selected from the 
users, and individual users; 
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FIGURE 8 is a representative schematic diagram illustrating the relationships 
among all possible documents on the Internet, a viewed selection of documents, and a 
typical set of bookmarked documents; 

FIGURE 9 is a block diagram illustrating the functional components and 
5 communications of a server-based implementation of the present invention; 

FIGURE 10 is a block diagram illustrating the functional components and 
communications of a client-based implementation of the present invention; 

FIGURE 1 1 is a flow chart illustrating the sequence of steps performed by a user's 
machine in the context of the server-based implementation of FIGURE 9; 
10 FIGURE 12 is a flow chart illustrating the sequence of steps performed by a user's 

machine in the context of the client-based implementation of FIGURE 10; 

FIGURE 13 is a block diagram illustrating the background processing typically 
performed by the bookmark database in a system according to the invention; 

FIGURE 14 is a flow chart illustrating the sequence of steps performed in 
15 generating a subject-matter recommendation in a system according to the invention; and 

FIGURE 15 is a flow chart illustrating the sequence of steps performed in 
generating an augmented search with ranked results in a system according to the 
invention. 
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DETAILED DESCRIPTION OF THE INVENTION 

The invention is described below, with reference to detailed illustrative 
embodiments. It will be apparent that the invention can be embodied in a wide variety of 
forms, some of which may be quite different from those of the disclosed embodiments. 
5 Consequently, the specific structural and functional details disclosed herein are merely 
representative and do not limit the scope of the invention. 

A bookmark system according to the present invention can be implemented as set 
forth in Fig. I. The exemplary system includes at least one user 110, and typically a 
plurality of users 1 10, 1 12, 1 14, and 1 16. Each user 1 10- 1 16 is coupled to a document 

10 repository 118, such as the Internet (or the World Wide Web), a corporate Intranet, a 
library, or any other collection of documents. Documents, in this context, refers to any 
data file containing information readable by a machine or a human; the term includes (but 
is not limited to) text files, formatted text files, bitmapped image files (including images 
representing text-based documents), vector-based image files, sound files, multimedia 

15 files, and any other data files of possible interest. Documents may be static or dynamically 
generated based on information in the URL or other request presented to access the 
document as well as other contextual information, such as the time of day. The repository 
1 18 may be situated on distributed servers such as Web servers on the Internet, a single 
group of dedicated servers such as a corporate information center, or a single host server. 

20 Also in communication with the repository 118 (and the users 110-116) is a 

bookmark database 120. As described in the summary set forth above, the bookmark 
database 120 maintains a set of bookmarks for each user 1 10- 1 16; each user may maintain 
private bookmarks, which are shielded by the database 120 from the other users, as well as 
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public bookmarks, which are made available by the database 120 for various uses by other 
users. The specific operation of the bookmark database 120 will be set forth in additional 
detail below. 

A user's primary interaction with the bookmark database 120 takes place through 
5 a main bookmark window 210 (Fig. 2) provided by the user's browser 122 (Fig. 1). The 
illustrated bookmark window 210 includes a list of bookmarks 212, a list of categories 
213, the user's screen name "cwixon" 214, and several cosmetic separators 216. A data 
entry area 2 18 is also provided, and will be discussed in further detail below. 

The user 1 10 can access bookmarks within the list 212 in several possible ways. 
10 By "clicking" on the text of a single bookmark (e.g., the White House bookmark 220), the 
user's browser 122 will open a new window and bring up the document referenced by the 
bookmark 220, in this case the White House's Web site. By "dragging" the bookmark 
220 into an existing browser window, the browser 122 will bring up the document in that 
window. In either case, the system, in its preferred embodiment, logs the event of 
15 accessing the bookmark 220 to facilitate tracking frequency and recency of use for all 
bookmarks. 

In the left side of the main bookmark window 210 next to the list of bookmarks 
212, there are three columns 222, 224, and 226 for informational icons representing 
whether the documents corresponding to each bookmark are available, relatively new, or 
20 popular. In the illustrated embodiment of the invention, the first column 222 is reserved 
for an icon representing that a particular document is presently unavailable. For example, 
an unavailability icon 228 is shown next to the 'This is a Bad Link" bookmark; the system 
is able to alert the user that no such document exists without the need for the user to 
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manually verify the site's availability. In one embodiment of the invention, the system is ,! 
able to recommend alternative documents when a preferred document is unavailable: that 
capability will be discussed in further detail below. 

The second column 224 is reserved for an icon representing that a particular 
5 document is new or has been revised within the last thirty days. For example, a newness 
icon 230 is shown next to the Infoseek bookmark; the presence of that icon in the 
presently implemented and illustrated embodiment tells the user that the Infoseek main 
page (the one referenced by the bookmark) has been updated recently, within the last 
thirty days. In an alternative embodiment of the invention, the newness icon 230 can be 

10 used in combination with the recency-of-access tracking performed by the invention, 
thereby alerting the user that a document has been updated since the user last accessed or 
viewed the document. 

The third column 226 is reserved for an icon representing the popularity of a 
particular document. In the illustrated embodiment, a popularity icon 232 is shown next 

15 to the AltaVista bookmark because that bookmark is present in over 50% of all users' 
bookmark collections. The popularity icon 232 can thus be an indication of the quality of 
the information likely to be found in the document, since other users are also relying upon 
it. Although the currently implemented and illustrated embodiment uses 50% (over all 
users) as the popularity threshold, it should be noted that other thresholds might also be 

20 usable, as this number is used simply for convenience. In alternative embodiments of the 
invention, the threshold percentage may be made a user-definable preference, or may be 
based on some other metric (such as the percentage over a specified group of users). 
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In a preferred embodiment of the invention, the meaning of each icon is explained 
via a pop-up message when the user's mouse pointer (or other selection tool) is positioned 
over the icon. For example, by positioning the mouse pointer over the unavailability icon 
228, a "Document Unavailable" message would be presented to the user. 
5 The icons in columns 222, 224, and 226 are presented to each user on the basis of 

information tracked and maintained by the bookmark database 120. The database 120 
tracks availability and newness for each bookmark in the background, without user 
intervention, to achieve some efficiencies that would not otherwise be possible when each 
user maintains a separate local collection of bookmarks. Specifically, and particularly in 

10 the case of popular bookmarks, the information on availability and newness can be 
updated for the benefit of plural users at one time through one simple attempted access 
operation by the bookmark database 120. For example, it is likely that many (or even all) 
of the users of the system will have a bookmark for "Yahoo !" The availability and 
newness of that site can be tracked once by the database 120; the information can then be 

15 propagated to each user through multiple instances of the main bookmark window 210. 
The background operations of the database 120 will be discussed in further detail below, 
in connection with Fig. 13. 

As suggested above, a user's bookmarks can be divided into categories (such as 
the categories in the list 213); the list 212 shown in Fig. 2 is the "top level" list in user 

20 cwixon's hierarchy, as illustrated by the "slash" 234 presented after the user's screen name 
214. This is consistent with the traditional Unix-like method for specifying hierarchies of 
directories, in which a slash character alone represents the root or top-level directory. The 
user 110 can access the other categories in the list 213 by clicking on those category 
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names. When that is done, the list of bookmarks 212 will be replaced with a different list ■ 
taken from the chosen category (such as News or Weather in the illustrated example), and 
the slash 234 will be followed by the name of the chosen category. After descending the 
hierarchy, the user 110 can return to the top level (or any intermediate level) by clicking 
5 on the screen name 2 14 or any following category name. 

The main bookmark window 210 contains a notation 236 that the displayed 
category (in this case, the top-level category) is private. When that is the case, only the 
user 110 that owns (Le., contributed) the list 212 can access those bookmarks. By 
selecting a "Publish" button 238 in the data entry area 218, the user 110 can make those 

10 bookmarks available to all users; otherwise, the bookmarks in the category remain private. 
In a preferred embodiment of the invention, a user can choose to publish any category of 
bookmarks (or even a single bookmark or selection of bookmarks) to the community of 
users as a whole, or only to selected groups of users. The concept of groups will be 
described in further detail below. 

15 Although the exemplary main bookmark window 210 shows the bookmarks for a 

single user, in a preferred embodiment of the invention, it is also possible to browse, view, 
and use public bookmarks, either as an entire categorized collection, or broken down via 
groups of users. 

Several other options are available in the main bookmark window 210. A "quick 
20 add" option 240 is available; when selected, any URL or document location dragged into 
the window 210 will be immediately added to the list 212 without any intermediate 
confirmation step. The ordinary "add" function of the main bookmark window 210 will 
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• cause a confirmation window (Fig. 5, described below) to appear before a bookmark is 
added via the drag-and-drop method. 

A search text-entry box 242 is also provided in the data entry area 218. By typing 
one or more keywords into the text-entry box 242 and pressing "Enter/' the system will 
5 search for bookmarks containing (either in the title or in the URL) the requested 
keywords. By selecting a "Search Public Bookmarks" option 244, the search can be 
extended to all users' public bookmarks (see Fig. 4, described below). 

The main bookmark window 210 also provides a command selection drop-down 
listbox 246; the contents of the command selection listbox 246 are shown in Fig. 3. By 
10 selecting various options in the listbox 246, the user can add bookmarks, separators, and 
categories; import and export bookmarks between the bookmark system of the invention 
and, for example, Netscape's internal bookmark system (described in the background 
section above), edit the user's preferences (such as password, e-mail address, etc.); log 
out of the system; edit a document; show a document (ordinarily performed by simply 
15 clicking or dragging a bookmark, as described above); or show a directory of users (used 
to access a particular user's public bookmarks). 

The functions available in the command selection drop-down listbox' 246, as 
illustrated in the window 3 10 of Fig. 3, involve simple data manipulation and will not be 
described in further detail (except in the context of the general operation of the system in 
20 Figs. 9- 12). These functions would be easily implemented by a person of ordinary skill in 
the art of Web-based application programming. 

As stated above, Fig. 4 is a search results window 410 illustrating a sample set of 
search results; the keyword entered into the text entry box 242 in the illustrated 
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embodiment was ''internet." Accordingly, the search results window 410 includes a list' 
412 of bookmarks containing, either in the title or URL, the word "internet; 1 The 
exemplary search was performed with the "Search Public Bookmarks" option 244 
selected, so the list 412 can include bookmarks from all users. The category in which each 
5 bookmark in the list 412 was found is presented next to the corresponding bookmark. For 
example, an "Internet Info" bookmark 414 was found in some user's "Internet" category; 
for privacy reasons, the user's identity is concealed. As with the main bookmark window 
210, the user can click or drag bookmarks from the search results window 410 to access 
the documents referenced by the bookmarks in the list 412. 

10 Fig. 5 illustrates an "Add New Bookmark" window 510 used by the user interface 

of the presently implemented embodiment of the invention. As shown, in its empty form, 
this window 510 is accessed by selecting the "add bookmark" command from the 
command selection listbox 246 (Fig. 2). The user 1 10 can then manually select a category 
512 in which to add the bookmark, enter the URL or other identifier 514 for the 

15 bookmark, and enter a title 5 16 for the bookmark. An "Add" button 5 18 is provided, and 
when chosen, the bookmark system adds the specified bookmark to the list 212. When 
the "Add New Bookmark" window 510 is accessed by dragging a link onto the main 
bookmark window 2 10, the category field 512 and URL field 5 14 are already filled in, and 
can be edited by the user if desired before confirming the action by pressing the "Add" 

20 button 5 18. 

Fig. 6 represents a bookmark editing window 610 presented by the user interface 
of the presently implemented embodiment of the invention. This window 610 is accessed 
by pressing an "Edit" button 248 in the main bookmark window 210 (Fig. 2). As shown 
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• (and as represented by a scrollbar 612 on the right side of the window 610, the editing 
window 610 has been scrolled down to reveal the bottom of the window; the top (not 
seen) includes the data entry area 218 (Fig. 2). 

A list 614 of bookmarks to be edited is presented within the editing window 610; 
5 the bookmarks are preceded by a column of checkboxes 616 available to indicate which 
bookmarks are to be edited. By selecting a "Select None" button 618 or a ''Select All" 
button 620, none or all of the checkboxes 616 will be selected, respectively. Editing 
operations, as indicated by the remaining buttons within the editing window 610, can then 
be performed on the selected bookmarks. For example, after selecting one or more 
10 bookmarks, pressing a "Delete" button 622 will remove the selected bookmarks from the 
list 614 (and from the list 212 in the main bookmark window 210). A "Move to" button 
624 and corresponding category selection listbox 626 are provided to move one or more 
selected bookmarks to a different category. Finally, a "Move Bookmarks to Top" button 
628 and a "Move Bookmarks to Bottom" button 630 are provided to facilitate moving 
15 one or more selected bookmarks around within the displayed category. As with the 
commands shown in the listbox 246, these editing commands will not be discussed in 
further detail as they represent simple data manipulation operations easily implemented by 
a person of ordinary skill in the art. 

As suggested in the summary section above, the present invention harnesses the 
20 power of online communities to allow enhanced search-and-retrieval and recommendation 
operations. These operations are enhanced through the use of data derived from a 
collection of users' shared bookmarks. ■ - 
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Millions of people use and participate in the Internet today. However, these users 1 
have many diverse interests. For example, some users might have a particular interest in 
financial information, while some other users might be interested in computer 
programming, and still other users are interested in video games. While traditional search 
engines are able to search the Internet as a whole, it is not usually possible to derive 
information from the various communities of users around the Internet. Systems such as 
Google, CLEVER, Direct Hit, and Alexa attempt to derive some additional information 
from aggregate interests manifested on the Internet as a whole, but are generally unable to 
derive any information from the preferences of select individuals or groups. 

The present invention uses communities of users as follows. In Fig. 7, the millions 
of users participating in the Internet are represented by eighteen representative users 710. 
Two groups 712 and 714 are highlighted. A first group 712 contains six users; for the 
purposes of this example, suppose that the first group 712 is interested in financial 
information. A second group 714 also contains six users; for exemplary purposes, 
suppose that the second group 7 14 is interested in computer programming. It should be 
noted that the groups need not be (and in this example are not) mutually exclusive, as one 
user 716 is a member of both the first group 712 and the second group 714. Moreover, 
not every user must have a defined interest. The present invention is able to use the 
preferences of the entire Internet 710, one or more groups 712 or 714, or even a single 
user 716 to provide recommendations on preferred documents and to enhance search 
queries and results. The operations performed in doing so will be described in further 
detail below in conjunction with Figs. 14 and 15. 
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Fig. 8 illustrates schematically a similar breakdown of documents on the Internet. 
The millions of documents available on the Internet are represented by 24 exemplary 
documents 810. While there are many, many documents available, only a small portion of 
them 812 are typically used or accessed by a community of users. And of those accessed, 
5 only a small number are preferred and bookmarked 814. The distillation of the entire 
Internet down to those documents that are bookmarked 814 is a powerful two-step filter 
that tends to pull out only the most relevant, interesting, and valuable documents. 
Moreover, when a community of users' bookmarks are shared, other users' efforts in 
locating useful documents can work to the entire community's advantage through a 

10 system according to the invention. 

At the system level there are two ways in which a system of the nature of the 
present invention can be implemented. First, the browser 112 can be used relatively 
passively, to collect user input and pass it along to the database 120 for processing. This 
presently preferred mode of operation is illustrated as a block diagram in Fig. 9. A user's 

15 system or terminal 910 hosts a Web browser 912 such as Netscape Navigator or 
Microsoft Internet Explorer; the browser 912 is able to interpret both HTML, and 
JavaScript (or another HTML-embeddable scripting language) by way of an HTML 
interpreter 914 and a JavaScript interpreter 916. The user's system 910 also includes an 
input device 917 allowing the user to interact with the system 910, as well as some storage 

20 space 918. 

The user's system 910 and browser 912 receive display information and scripts 
(arrow 920) from the database 922; the browser 912 simply passes along user input 
(arrow 924) to the database 922. Essentially all processing is performed at the database 
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922 by way of a bookmark server 926 and a data processor 928. The details of the 
processing will be discussed below in conjunction with Figure 1 1. 

An alternate mode of operation, in which some of the processing is performed by 
the user's system, is set forth as a block diagram in Fig. 10. In this case, a user's system 
or terminal 10 10 hosts a Web browser 1012, which in cum includes an HTML interpreter 
1014 and a language interpreter 1016, The language interpreter 1016 is able to receive 
and execute computer programs in a high-level language such as Java; most modern Web 
browsers include that capability. Like the system illustrated in Fig. 9, this system also 
includes a user input device 1017 and temporary storage 1018. 

In the mode of Fig. 10, the browser 1012 receives bookmark data and a shared 
bookmarks ("SBM"). computer program (arrow 1020) from the database 1022 at the 
beginning of a session of use; the SBM program allows the user's system 1010 to perform 
many of the operations disclosed herein (except for those that require large amounts of 
data in the database). For example, a user's bookmark collection can be maintained and 
modified locally at the user's system 1010 without sending data to and receiving data from 
the database 1022. At the end of a session of use, the modified bookmark collection (and 
any other collected information) is transferred back (arrow 1024) to the database 1022 for 
storage and manipulation by the database. 

As stated above, many operations performed by the shared bookmark system can 
be executed at the user's system 1010 without any further communication with the 
database 1022. However, operations that tend to access a lot of data, such as database 
queries (arrow 1024) for search-and- retrieve operations and recommendations based on 
other users' bookmarks, still are preferably transferred back to the database 1022. It is 
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*■ simply impractical for all shared bookmarks from a potentially very large community of 
users to be transferred to the user's system 1010 at the beginning of each session. 
Accordingly, these search and recommendation operations are acted upon by the database 
1022 (through the operation of a bookmark server 1026 and a data processor 1028), and 
5 results are sent back to the user's system 1010 (arrow 1020). The details of the 
processing performed in this embodiment will be discussed below in conjunction with 
Figure 12. 

In both of these cases, the persistent data maintained by the shared bookmark 
system is kept at the database 120 (Fig. I); the user's local storage 124 is used only for 

10 temporary storage during a session. Accordingly, if the user 110 wishes to access the 
Internet 1 18 from a different terminal 126, the shared bookmark system is still operational 
(provided the user is able to log in using a memorized screen name and password) because 
all necessary data is received from the database 120 at the beginning of a session, and sent 
back to the database 120 at the conclusion of the session. Any custom software required, 

15 other than the Web browser, is downloaded from the server 120 to the alternate terminal 
126. 

The approach set forth in Fig. 9 has some advantages, in that a complicated 
bookmark-processing program and a potentially large collection of bookmarks do not 
need to be downloaded from the database 120 to the user 1 10 at the beginning of each 
20 session. This reduces any lag or delay between the user initiating the service and the 
availability of the bookmarks, which can be an inconvenience. 

The approach set forth in Fig. 10 has a different set of advantages. To the extent 
there are any communications bottlenecks between the database 120 and the user 1 10, the 
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effects of these bottlenecks will be reduced when the user 1 10 is able to perform as much* 
computation as possible, without the need to shuttle information back and forth between 
the user 110 and the database 120. This approach will also be advantageous if the 
database 120 tends to be computationally overloaded. However, as stated above, the 
database 120 still must be accessed for certain operations. 

Figure 1 1 illustrates the steps performed in the passive client-side embodiment of 
the invention (illustrated in block form in Fig. 9). The system operates by simply awaiting 
user input (step 1110), transmitting that user input from the user's system 110 to the 
database 120 (step 1120). receiving a response from the database 120 (step 1130), and 
refreshing the display (step 1 140) according to specific HTML and JavaScript instructions 
received from the database 120. As stated elsewhere in this document, the specific 
operations on the database side of the system typically represent simple data manipulation 
operations, which will not be described further. To the extent those operations are more 
complicated or contain novel steps, they will be described in further detail below. 

Figure 12 illustrates the steps performed in the active client-side embodiment of 
the invention (illustrated in block form in Fig. 10). The system operates by the user 1 10 
initially receiving the shared bookmark program and bookmark collection from the 
database 120 (step 1210). The user's system then awaits user input (step 1220) and 
processes the input (step 1230) to determine if it requires the processing resources of the 
database 120. If the user input comprises a query (step 1240) involving other users' 
bookmarks, the query is transmitted (step 1250) to the database 120 and a response is 
received (step 1260) from the database. The function of the database 120 at this point will 
be discussed in further detail below with reference to Figs. 14 and 15. If the user input is 
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' not a query, the user's bookmark collection is updated (step 1270) as specified in the 
shared bookmark program. In both cases, the display is then refreshed (step 1280) to 
reflect the operation, regardless of whether it was performed locally or remotely. At the 
end of a session, the user's system 1 10 transmits back to the database 120 all necessary 
5 updated information, including any changes to the user's bookmark collection and any 
logged events (such as bookmark accesses) used by the invention to determine frequency 
and recency of use. 

As described above, the database 120 performs certain operations in the 
background maintain the bookmark collections of its users; those operations are set forth 

10 in Fig. 13. For reasons set forth in detail above, the database 120 monitors changes (step 
1310) for each document referred to in each user's bookmark collection. This operation 
can be performed on a regular basis, for example hourly or daily. For the presently 
implemented and preferred embodiment of the invention, an icon indicates to the user 
whether a document has been updated within the last thirty days (see Fig. 2), so a daily 

15 check for updates is sufficient. To accomplish this task, the database 120 can keep either 
a cached copy of the document referred to (thereby enabling word-for-word comparisons 
between the old cached copy and an updated version), or preferably, can maintain a simple 
suitably robust hash value representing the document's contents, whereby any change in 
the document's contents will cause the hash value to change. 

20 The database 120 also monitors the availability (step 1320) for each document 

referred to in each user's bookmark collection. This operation can also be performed on a 
regular basis. For the presently implemented and preferred embodiment of the invention, 
an icon indicates to the user whether a document is available (see Fig. 2). To derive this 
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information* the database periodically attempts to access each document, and if an HTTP 
error (such as kt 404 Not Found") or no data is returned, the document is marked 
unavailable for all users who have the bookmark in their collection. Unavailable 
documents are checked again at a later time. 
5 The database 120 monitors the popularity (step 1330) for each document referred 

to in each user's bookmark collection by periodically determining how many users, out of 
the total number of system users, have a bookmark in their collection. This information is 
also represented by an icon (see Fig. 2). As stated above, various other metrics of 
popularity are trackable by the system, such as frequency and recency of access. Every 

10 time a bookmark is used by a user to access a document, the time, date, and nature of that 
access is logged. Accordingly, the system is able to use various popularity metrics in the 
enhanced searching and recommendation operations discussed below. 

In one embodiment of the invention, metadata is extracted from documents by the 
database 120 (step 1340). In the case of HTML documents, such metadata may include 

15 information on the date and time a document was created, the author of the document, 
search keywords, and many other possible items of data that are typically concealed when 
a user views a document. This information can optionally be kept with bookmarks in the 
database 120 to facilitate further search options. 

In an embodiment of the invention, the contents of documents referred to by users' 

20 bookmarks are summarized (step 1350) and stored at the database 120. Alternatively, if 
summarization is not performed in the background, it can be specifically performed at the 
time of a search or upon a user request for a summary. Several summarization techniques 
are well known in the art. A particularly advantageous summarization method is set forth 



24 



WO 00/67159 PCT/US00/12042 
•« in U.S. Patent No. 5,638,543 to Pedersen et aL, entitled "Method and Apparatus for 
Automatic Document Summarization," the disclosure of which is hereby incorporated by 
reference for all it teaches as though set forth in full herein. In either case, document 
summaries optionally can be presented to users as pan of a list of search results or within 
5 a list of bookmarks, enabling the users to better and more easily determine which 
documents from a collection are most relevant to their particular interests. 

A similar technique can be used to summarize a group or collection of documents. 
Upon a user's request (this would not typically be performed in the background), a 
document summary can be generated based on a concatenation of selected documents, or 
10 even all documents referenced in a category of bookmarks. 

The database 120 also maintains itself (step 1360) in the background by analyzing 
users' bookmark collections, eliminating duplicate bookmark entries as necessary, and 
performing additional tasks (such as "garbage collection") well known in the art of 
computer systems. 

15 Finally, as discussed above, the browsing, searching, and bookmark-using habits of 

users of the shared bookmark system of the invention all contribute additional information 
to the system for use in improving and refining user and group profiles. For example, if a 
user in a computer programming group searches for, views, and ultimately bookmarks 
several sites relating to, say, the Objective C programming language, then the user's 

20 profile will be automatically updated to include information derived from the bookmarks, 
and the computer programming group's profile can also be similarly updated. This is 
accomplished, as will be described in further detail below, by calculating a content vector 
representative of the bookmarks in a user's (or group's) collection. 
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The concept of groups, as generally discussed above in connection with Fig. 7, is* 
central to the present invention. While the embodiment of the invention disclosed and 
described above, particularly in the user interface windows of Figs. 2-6, does not employ 
the concept of groups for many operations, it should be recognized that organizing the 
5 shared bookmark system's users into groups is a powerful way to capture preferences and 
relevant documents. 

For example, in the user directory introduced above in connection with Fig. 3, 
there can also be group membership information. In an embodiment of the invention, a 
user can manually choose to become a member of a group having similar interests (as 

10 evidenced by manually inspecting the users' public bookmarks), or in an alternative 
embodiment, can be assigned automatically to groups based on clustering on the user's 
public bookmarks (or, preferably, the contents of the documents pointed to by the 
bookmarks). For a detailed description of methods of document clustering, see U.S. 
Patent No. 5,442,778 to Pedersen et aL, entitled "Scatter-Gather: A Cluster-Based 

15 Method and Apparatus for Browsing Large Document Collections," the disclosure of 
which is hereby incorporated by reference for all it teaches as though set forth in full 
herein; see also U.S. Patent No. 5,659,766 to Saund et aL, entitled "Method and 
Apparatus for Inferring the Topical Content of a Document Based Upon its Lexical 
Content Without Supervision," the disclosure of which is also hereby incorporated by 

20 reference. One method of automatically grouping users involves identifying the centroid 
related to each user's public bookmark vectors (either collectively or on a category-by- 
category basis) in document space, and collecting the mutually-nearest sets of users into 
topic-related groups. Alternatively, a less-automatic method includes computing a 



WO 00/67159 PCT/USOO/12042 

centroid, as above, but using that information simply to recommend related groups to the 
user. 

Another possibility, related to the foregoing automatic grouping scheme, is to 
create virtual groups based on the topic categories in each user's public bookmarks. For 

5 example, if a user has a public bookmark category entitled "Java," that user can be treated 
as belonging to a group having an interest in the Java programming language. 

As stated above, each user and group (however created) can have a profile 
associated therewith. In the preferred embodiment of the invention, a user's profile 
consists simply of a normalized content vector representing the aggregate contents of all 

10 of the user's public bookmarks. For a description of how this vector is calculated, see 
U.S. Patent No. 5,442,778 to Pedersen et aL, described above. Similarly, a profile for a 
group includes a normalized content vector representing the aggregate contents of all 
public bookmarks belonging to the users within the group. The user and group profiles 
are used in the search and recommendation aspects of the invention, which will be 

15 described in further detail below. 

Referring now to Fig. 14, a recommendation service according to the invention is 
set forth as a flow chart. Preferably, this service is initiated by a user by selecting a 
command in the main bookmark window 210 and entering text representative of the 
desired subject (step 1410). The user then identifies the context (step 1420) within which 

20 the recommendation should be generated. This step is preferably performed by manually 
selecting a user or group profile, which as described above, has a content vector 
associated therewith. If no existing single user or group is satisfactory, a special-purpose 
group can be assembled by the user by manually selecting users and having those users' 
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profiles merged into a special- purpose content vector. The user then selects a level of 
"relevance feedback" (step 1430). Relevance feedback allows the user to select whether 
the desired documents are those similar to the selected context or dissimilar to the selected 
context. A known example of positive relevance feedback is the "more like this" option 
provided by the Excite search engine. 

The subject, context, and relevance feedback are then processed by the database 
120 to generate recommendations (step 1440). This step uses the popularity (proportion 
of users having a bookmark) metric 1450. frequency of use metric 1460, and recency of 
use metric 1470 described above. The recommendation generation step searches the 
public bookmarks belonging to the user or group selected as the context (or alternatively, 
all public bookmarks) for the keywords identified as the subject. These keywords can be 
found in the title or URL of the public bookmarks, or alternatively, in the content 
belonging to the public bookmarks. The matches are then analyzed with respect to the 
content vector and the popularity, frequency, and recency metrics. Alternatively, the 
keywords are combined with the content vector into an enhanced keyword vector, which 
is then compared to the entire search corpus in a single search step and then ranked 
according to popularity, frequency, and recency. 

In an alternative embodiment of the invention, the recommendation service is also 
able to use link structure (as described above in connection with the Google and CLEVER 
systems discussed in the background section above, for example) in generating 
recommendations. By way of example, the number of inlinks or outlinks (weighted or 
unweighted), as well as any other link-specific metrics readily apparent to those skilled in 
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the art, may be weighted and incorporated into the step of generating recommendations 
(step 1440) via the content vector, popularity, frequency, and recency. 

Alternatively, a spreading activation methodology may be used to re-rank 
recommendations (or search results, as will be described below), or may be used as a 
5 weighted factor in the recommendation operation set forth above. See U.S. Patent No. 
5,835,905 to Pirolli et aL, entitled "System for Predicting Documents Relevant to Focus 
Documents by Spreading Activation Through Network Representations of a Linked 
Collection of Documents," the disclosure of which is hereby incorporated by reference for 
all it teaches as though set forth in full herein. Spreading activation techniques are based 

10 on representations of Web pages as nodes in graph networks representing usage, content, 
and hypertext relations among Web pages. Conceptually, activation is pumped into one or 
more of the graph networks at nodes representing some starting set of Web pages (Le. 
focal points, which in the context of the present invention may be a set of highly ranked 
recommendations or search results) and it flows through the arcs of the graph structure, 

15 with the amount of flow modulated by the arc strengths (which might also be thought of 
as arc flow capacities). The asymptotic pattern of activation over nodes will define the 
degree of predicted relevance of Web pages to the starting set of Web pages. By selecting 
the topmost active nodes or those above some set criterion value, Web pages may be 
aggregated and/or ranked based on their predicted relevance. 

20 If the user selected positive relevance feedback (Le., "documents like these"), the 

closest context matches in the previously-keyword-matched public bookmark collection 
are returned as the highest-ranking. If the user selected negative relevance feedback (Le., 
"documents unlike these"), the closest context matches in the collection are given the 
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lowest rankings. The recommendation list is then returned to the user for viewing (step" 
1480). 

It should be noted that recommendations need not be provided only in the context 
of an explicit request for recommendations in through the main bookmark window 210; 
5 recommendations can also be provided while a user is browsing the Web. If a Web page 
the user is viewing contains a link that is also a popular link (by any of the metrics defined 
above) in the shared bookmark collection (as a whole, or within one or more groups), then 
the user can be alerted to that via the presentation of a message in the browser window. 
Alternatively, if there is a historical pattern of documents chosen from the shared 

10 bookmark collection (as defined by the frequency and recency metrics), then that pattern 
can be highlighted for the user. 

One embodiment of the recommendation service is adapted to provide a user with 
a "substitute" bookmark when a preferred document is unavailable, as indicated by the 
unavailability icon 228 (Fig. 2). This capability is implemented through a variation on the 

15 recommendation service set forth in Fig. 14. Specifically, instead of entering text 
representative of the desired subject (step 1410), the user identifies an unavailable 
bookmark. Information stored by the database 120 pertaining to the unavailable 
bookmark is then used to generate a recommendation; that information may (in various 
embodiments of the invention) include a content vector, keywords, or a summary of the 

20 expected (but missing) content. 

A search and retrieval system according to the invention is set forth in Fig. 15 as a 
flow chan. As with the recommendation service of Fig. 14, the user begins by formulating 
a keyword query (step 1510), identifying a context (step 1520), and identifying relevance 
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feedback (step 1530). The query, context, and feedback are provided to the database 120, 
where the query is augmented (step 1540). In a preferred embodiment of the invention, 
query augmentation is performed by selecting the most important (Le., highest magnitude) 
words from the context's content vector and adding them to the query. It should be noted 
that various other methods of augmenting the query with the user's preferred document 
collection are possible, as suggested above, ranging from the decomposition of the entire 
collection into a single vector, the selective decomposition of portions of the collection 
based upon similarity or dissimilarity to the initial query or based upon groups, to 
completely augmenting the query with document collection. 

If positive relevance feedback (Le., "documents like these") has been selected, the 
query is augmented by adding the additional context words as words that should be found 
in the results; if negative feedback has been selected, the query is augmented by adding the 
additional context words as words that should not be found in the results. It should be 
observed that the user's initial query is being augmented by introducing additional search 
words for a simple reason: traditional search engines generally operate only on search 
terms, and would not recognize a content vector, context, or information in any other 
form. While various search engines use different syntaxes for specifying positive and 
negative relevance feedback, in most cases, some degree of augmentation according to the 
invention is possible. 

The query is then performed. In a preferred embodiment, the query is performed 
on the database 120 of public bookmarks (step 1550) at the same time it is performed on 
an external search engine (step 1560). If the community of users is sufficiently large, 
results obtained from the public bookmarks may be superior in quality to those received by 
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querying the Internet; this approach is similar to the recommendation system described 
above (Fig. 14). The search results obtained from the database 120 can be presented to 
the user separately from or as a part of the search results obtained from the Internet. 

The results are then ranked (step 1570) according to the user's selected context, as 
with the recommendations described above (see step 1440). Also, the user may be given 
the option to employ popularity, frequency, and recency in the ranking operation. And in 
an alternative embodiment, as described above, link structure may also be used. 

The relative weights of the context match, link structure, popularity, frequency, 
recency, and any other metrics in the ranking operation are matters of preference, and in a 
preferred embodiment of the invention, can be adjusted by the user. In an alternative 
embodiment of the invention, the weights are dynamic and adjustable by the system based 
on user habits. For example, if a user consistently chooses relatively low-ranked 
selections in search results lists, that may be seen as an indication that the current metric 
weights are incorrect, leading to a de-emphasis of the highly weighted factors. Such 
learned weightings can be maintained as global system defaults or, preferably, applied on a 
user-by-user basis. 

Alternatively, as described in conjunction with the recommendation service above, 
a spreading activation methodology may be used to re-rank search results, or as a factor in 
the ranking operation set forth above. 

The ranked results are finally returned (step 1580) to be viewed by the user. As 
stated above, the results retrieved from the public bookmark collection can be presented 
separately from the Internet results, or they can be incorporated into the same list (most 
likely with higher scores, because of influence from the popularity metric). In a preferred 
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* embodiment, the results retrieved from the public bookmark collection are highlighted to 
identify their origin. 

It should be noted that a search service according to the invention need not 
provide both query augmentation and results ranking. Advantageous results can be 
5 obtained by using either technique alone. For example, a query can be augmented by a 
system according to the invention, after which Internet search engine results are viewed 
without further modification. Or alternatively, a user- formulated query can be passed 
directly to a search engine, with the results being passed through the context and 
popularity-based ranking scheme of the invention. 

10 'One further embodiment of the invention incorporates automatic document 

categorization. If this optional feature is implemented, a user can create a hierarchy of 
bookmarks without having to manually create the categories. Several topical 
categorization methods are known in the art; for example "k nearest neighbors," "support 
vector machines," and "winnow," among other methods, can be used. For several detailed 

15 examples of how document categories may be formed, see U.S. Patent No. 08/842,926 to 
Pirolli et aL, entitled "System for Categorizing Documents in a Linked Collection of 
Documents"; U.S. Patent No. 5,526,443 to Nakayama, entitled "Method and apparatus 
for highlighting and categorizing documents using coded word tokens"; and U.S. Patent 
No. 5,687,364 to Saund et aL, entitled "Method for Learning to Infer the Topical Content 

20 of Documents Based Upon Their Lexical Content." With the automatic categorization 
feature of the invention enabled, to add a new bookmark, a user need only drag a link 
from the Web browser onto the main bookmark window 210; the automatic categorization 
method will ensure that the new bookmark is properly categorized within the user's 
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hierarchy (creating a new category, if necessary). Optionally, the user can specify whether* 
the new bookmark is to be private, shared with a group, or public; the categorization 
method will then act accordingly. 

In one embodiment of the invention, the automatic categorization scheme 
5 described above uses, as a topic reference, a global hierarchy of categories. A document 
or collection of documents is compared (by the scheme described above) against the 
possible topics in the global hierarchy, and the user is presented with a resulting category 
name that %4 fits" properly within the global hierarchy. This approach has the advantage of 
ensuring that searches across multiple users' public bookmarks return consistent category 
10 names. 

Deriving the global hierarchy can be accomplished as follows. First, represent 
each category as the centroid of the titles of the documents (or, preferably, the content of 
the documents). The centroids of the categories are then clustered into a preferred 
number of top-level clusters (e.g., ten clusters). Then recursively cluster each of the 
15 clusters until the "leaves" of the hierarchy are individual clusters. 

While certain exemplary embodiments of the invention have been described in 
detail above, it should be recognized that other forms, alternatives, modifications, versions 
and variations of the invention are equally operative and would be apparent to those 
skilled in the art. The disclosure is not intended to limit the invention to any particular 
20 embodiment, and is intended to embrace all such forms, alternatives, modifications, 
versions and variations. 

Accordingly, while this specification, for the sake of clarity and disclosure, at times 
uses specific terminology and constructs to refer to certain aspects of the invention and its 
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0 operating environment, it will be recognized that the invention set forth herein is 
applicable in other areas, as well. For example, this specification frequently refers to the 
Internet, Web sites, Web pages, and documents; it should be observed that the invention is 
equally applicable to other types of documents, databases, and document collections. 
5 Moreover, references to bookmarks, favorites, and preferences are not intended to be 
limited to any particular implementation (or set of implementations) for retaining 
information on users' browsing habits, but instead should be construed to apply to all 
means and methods for specifying and retaining such information. 

Similarly, HTML is described as the most common format or language for 

10 describing documents on the Web; it should be noted that other document formats (such 
as XML, SGML, plain ASCII text, plain Unicode text, and other standard and proprietary 
formats) are also in use on the Internet and in various other document- based applications; 
this invention will function equally well in the context of networks utilizing other formats 
or even multiple formats. For the purposes of certain aspects of the invention (such as 

15 summarization and recommendation), the only limitation is that the format be 
decomposable into a language (which can even be accomplished, in image-based formats, 
through character recognition). The term "document" is intended to refer to any raachine- 
or human-readable data file (or collection of related files) from which information can be 
retrieved. 

20 URLs are typically used to access information on the Internet, and frequently on 

other networks, as welL However, it should be recognized that other means of specifying 
the location, identity, and nature of a requested document are also possible; such 
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alternative schemes would be apparent to a practitioner of ordinary skill in the art, aiid the ' 
invention is deemed to cover these variations. 

When the present disclosure refers to Web browsers, it should be recognized that 
other information access applications are also relevant, including but not limited to 
5 information sharing and access tools such as Lotus Notes, database systems, and other 
data sharing and retrieval applications. 
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What is claimed is: 

1. A method for generating recommendations from a collection of shared 
document bookmarks contributed by a plurality of users, wherein each shared document 
bookmark represents a document, comprising the steps of: 

receiving at least one subject keyword; 

searching at least a portion of the collection of shared document bookmarks; and 
retrieving a group of bookmarks that match the subject keyword. 

2. The method of claim I, further comprising the steps of: 
identifying a context within the collection; and 

ranking the group of bookmarks based a computed match with the context. 

3. The method of claim 2, wherein the context comprises a profile for a group 
of users chosen from the plurality of users. 

4. The method of claim 2, wherein the context comprises a profile for a single 
user chosen from the plurality of users. 

5. The method of claim 4, wherein the profile comprises a content vector 
derived from at least one document represented by at least one bookmark in at least one 
selected topical category of bookmarks contributed by the single user. 
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6. The method of claim 3, wherein the profile comprises a content vector' 
derived from a document represented by at least one shared bookmark contributed by the 
group. 

7. The method of claim 3, wherein the profile comprises a content vector 
derived from at least one document represented by at least one bookmark in at least one 
selected topical category of bookmarks contributed by the group. 

8. The method of claim 2, wherein the context comprises a profile for the 
plurality of users, said profile comprising a content vector derived from at least one 
document represented by at least one bookmark in at least one selected topical category of 
bookmarks contributed by the plurality of users. 

9. The method of claim 2, further comprising the steps of: 
identifying the popularity of each bookmark in the group of bookmarks; and 
re-ranking the group of bookmarks based on the popularity. 

10. The method of claim 9, wherein the step of identifying the popularity of 
each bookmark in the group of bookmarks comprises determining what fraction of users 
in the plurality of users contributed the bookmark. 
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1 L. The method of claim 2, further comprising the steps of: 

identifying the frequency of access of each bookmark in the group of bookmarks; 



10 



and 



and 



re-ranking the group of bookmarks based on the frequency. 

12. The method of claim 2, further comprising the steps of: 

identifying the recency of access of each bookmark in the group of bookmarks; 

re-ranking the group of bookmarks based on the recency. 

13. The method of claim 2, further comprising the steps of: 
identifying a link structure of each bookmark in the group of bookmarks; and 
re-ranking the group of bookmarks based on the link structure. 



15 14. The method of claim 13, wherein the link structure comprises a computed 

inlink weight combined with a computed outlink weight. 

15. The method of claim 14, wherein the computed inlink weight is determined 
from a bookmark's number of inlinks, and the computed outlink weight is determined 

20 from a bookmark's number of outlinks. 

16. The method of claim 2, further comprising the step of re-ranking the group 
of bookmarks based on a spreading activation analysis of the group of bookmarks. 
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17. The method of claim 1, further comprising the steps of: 
identifying a context within the collection; 

identifying the popularity of each bookmark in the group of bookmarks; 
identifying the frequency of access of each bookmark in the group of bookmarks; 
5 identifying the recency of access of each bookmark in the group of bookmarks; 

combining a computed match with the context, the popularity, the frequency, and 
the recency for each bookmark into a composite measure; and 

ranking the group of bookmarks based on the composite measure. 

10 18. The method of claim 1, further comprising the steps of: 

identifying a context within the collection; 

identifying a group of users comprising at least one user selected from the plurality 
of users; 

identifying the popularity of each bookmark in the group of bookmarks with 
15 respect to the group of users; 

identifying the frequency of access of each bookmark in the group of bookmarks 
with respect to the group of users; 

identifying the recency of access of each bookmark in the group of bookmarks 
with respect to the group of users; 
20 combining a computed match with the context, the popularity, the frequency, and 

the recency for each bookmark into a composite measure; and 

ranking the group of bookmarks based on the composite measure. 
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19. A method for searching a document repository based on information from 
a collection of shared document bookmarks contributed by a plurality of users, wherein 
each shared document bookmark represents a document, comprising the steps of: 

receiving at least one query keyword; 

augmenting the query with at least one additional keyword derived from the 
information; 

searching the document repository; and 

retrieving a group of documents that match the query keyword. 

20. The method of claim 19, wherein the augmenting step comprises the steps 

of: 

identifying a context within the collection; and 

identifying at least one additional keyword within the context. 

21. The method of claim 20, wherein the context comprises a profile for a 
group of users chosen from the plurality of users. 

22. The method of claim 19, wherein the context comprises a profile for a 
single user chosen from the plurality of users, 

23. The method of claim 22, wherein the profile comprises a content vector 
derived from at least one document represented by at least one bookmark in at least one 
selected topical category of bookmarks contributed by the single user. 
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24. The method of claim 21, wherein the profile comprises a content ' vector 
derived from a document represented by at least one shared bookmark contributed by the 
group. 

5 25. The method of claim 21, wherein the profile comprises a content vector 

derived from at least one document represented by at least one bookmark in at least one 
selected topical category of bookmarks contributed by the group. 

26. The method of claim 20, wherein the context comprises a profile for the 
10 plurality of users, said profile comprising a content vector derived from at least one 

document represented by at least one bookmark in at least one selected topical category of 
bookmarks contributed by the plurality of users. 

27. The method of claim 20, further comprising the steps of: 

15 identifying the popularity of each document in the group of documents; 

ranking the group of documents based on the popularity. 

28. The method of claim 27, wherein the step of identifying the popularity of 
each document in the group of documents comprises determining what fraction of users in 

20 the plurality of users contributed a bookmark representative of the document. 
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29. The method of claim 20, further comprising the steps of: 

identifying the frequency of access of each document in the group of documents; 
ranking the group of documents based on the frequency. 

30. The method of claim 20, further comprising the steps of: 

identifying the recency of access of each document in the group of documents; 
ranking the group of documents based on the recency. 

31. The method of claim 20, further comprising the steps of: 
identifying a link structure of each document in the group of documents; and 
re-ranking the group of documents based on the link structure. 

32. The method of claim 3 1, wherein the link structure comprises a computed 
inlink weight combined with a computed outlink weight. 

33. The method of claim 32, wherein the computed inlink weight is determined 
from a document's number of inlinks, and the computed outlink weight is determined from 
a document's number of outlinks. 

34. The method of claim 20, further comprising the step of re-ranking the 
group of bookmarks based on a spreading activation analysis of the group of bookmarks. 
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35. The method of claim 19, further comprising the steps of: 
identifying a context within the collection; 

identifying the popularity of each document in the group of documents; 
identifying the frequency of access of each document in the group of documents; 
5 identifying the recency of access of each document in the group of documents; 

combining a computed match with the context, the popularity, the frequency, and 
the recency for each document into a composite measure; and 

ranking the group of documents based on the composite measure. 

10 36. The method of claim 19, further comprising the steps of: 

identifying a context within the collection; 

identifying a group of users comprising at least one user selected from the plurality 
of users; 

identifying the popularity of each bookmark in the group of documents with 
15 respect to the group of users; 

identifying the frequency of access of each bookmark in the group of documents 
with respect to the group of users; 

identifying the recency of access of each bookmark in the group of documents with 
respect to the group of users; 
20 combining a computed match with the context, the popularity, the frequency, and 

the recency for each document into a composite measure; and 

ranking the group of documents based on the composite measure. 
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37. A method for searching a document repository based on information from 
a collection of shared document bookmarks contributed by a plurality of users, wherein 
each shared document bookmark represents a document, comprising the steps of: 

receiving at least one query keyword; 
5 searching the document repository; and 

retrieving a group of documents that match the query keyword; 
identifying a context within the collection; and 

ranking the group of documents based on each document's computed match with 
the context. 

10 

38. The method of claim 37, further comprising the step, prior to the searching 
step, of augmenting the query with at least one additional keyword derived from the 
information. 

15 39. The method of claim 37, wherein the context comprises a profile for a 

group of users chosen from the plurality of users. 

40 The method of claim 37, wherein the context comprises a profile for a 
single user chosen from the plurality of users. 

20 

41. The method of claim 40, wherein the profile comprises a content vector 
derived from at least one document represented by at least one bookmark in at least one 
selected topical category of bookmarks contributed by the single user. 
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42. The method of claim 39, wherein the profile comprises a content vector 
derived from a document represented by at least one shared bookmark contributed by the 
group. 

5 43. The method of claim 39, wherein the profile comprises a content vector 

derived from at least one document represented by at least one bookmark in at least one 
selected topical category of bookmarks contributed by the group. 

44. The method of claim 37, wherein the context comprises a profile for the 
10 plurality of users, said profile comprising a content vector derived from at least one 

document represented by at least one bookmark in at least one selected topical category of 
bookmarks contributed by the plurality of users. 

45. A method for searching a document repository based on information from 
15 a collection of shared document bookmarks contributed by a plurality of users, wherein 

each shared document bookmark represents a document, comprising the steps of: 
receiving at least one query keyword; 
searching the document repository; and 

retrieving a group of documents that match the query keyword; 
20 identifying a context within the collection; 

identifying the popularity of each document in the group of documents; 
identifying the frequency of access of each document in the group of documents; 
identifying the recency of access of each document in the group of documents; 
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combining a computed match with the context, the popularity, the frequency, and 
the recency for each document into a composite measure; and 

ranking the group of documents based on the composite measure. 

46. A method for searching a document repository based on information from 
a collection of shared document bookmarks contributed by a plurality of users, wherein 
each shared document bookmark represents a document, comprising the steps of: 

receiving at least one query keyword; 

searching the document repository; and 

retrieving a group of documents that match the query keyword; 
identifying a context within the collection; 

identifying a group of users comprising at least one user selected from the plurality 
of users; 

identifying the popularity of each document in the group of documents with 
respect to the group of users; 

identifying the frequency of access of each document in the group of documents 
with respect to the group of users; 

identifying the recency of access of each document in the group of documents with 
respect to the group of users; 

combining a computed match with the context, the popularity, the frequency, and 
the recency for each document into a composite measure; and 

ranking the group of documents based on the composite measure. 



47 



WO 00/67159 PCT/USOO/12042 

47. A method of adding a bookmark to a collection of shared dpcument 
bookmarks contributed by a plurality of users, wherein each shared document bookmark 
represents a document, and the collection comprises a plurality of categories, comprising 
the steps of: 

5 receiving a data item identifying a document; 

determining a category of the collection of shared document bookmarks in which 
to store the data item; and 

storing the data item as a bookmark in the category of the collection. 

10 48. The method of claim 47, wherein the step of determining a category 

comprises the substeps of: 

identifying a topic corresponding to the document; 

comparing the topic to a first list of topics in a user-specific hierarchy of 
categories; 

15 if the topic is in the first list, identifying the category within the user-specific 

hierarchy corresponding to the topic; 

if the topic is not in the first list, 

comparing the topic to a second list of topics in a global hierarchy of 

categories; 

20 if the topic is in the second list, 

identifying the category within the global hierarchy corresponding 

to the topic; and 
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establishing a category within the user-specific hierarchy 
corresponding to the topic; 

if the topic is not in the second list, 

establishing a category within the global hierarchy corresponding to 

the topic; and 

establishing a category within the user-specific hierarchy 
corresponding to the topic. 

49. The method of claim 48, wherein each user has a user-specific hierarchy of 
categories, and a global hierarchy of categories comprises an aggregation of all user- 
specific hierarchies. 

50. The method of claim 48, wherein the global hierarchy of categories is 
initially determined by the steps of: 

for each bookmark in the collection of shared document bookmarks, identifying a 
content vector corresponding to the bookmark; 

clustering the content vectors into a plurality of clusters; and 

recursively repeating the clustering step on each cluster in the plurality of clusters 
to derive a hierarchy of clusters; and 

storing the hierarchy of clusters as the global hierarchy of categories. 
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51. A system for maintaining a collection of shared document bookmarks 
contributed by a plurality of users, wherein each shared document bookmark represents a 
document in a document repository, comprising: 

a plurality of user terminals in communication with the repository; 

a database in communication with the repository and the plurality of user 
terminals, wherein the database is adapted to store the collection of shared document 
bookmarks; and 

software adapted to maintain the collection of shared document bookmarks. 

52. The system of claim 51, wherein each user terminal includes a browser. 

53. The system of claim 51, wherein a first portion of the software is executed 
by the database, and a second portion of the software is executed by each user terminal. 

54. The system of claim 53, wherein the second portion of the software is 
downloaded on demand from the database to a user terminal. 

55. The system of claim 54, wherein at least a portion of the collection of 
shared document bookmarks is downloaded on demand from the database to a user 
terminal. 
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56. The system of claim 55, wherein the portioa of the collection of shared 
document bookmarks is uploaded to the database from the user terminal upon completion 
of a session of use. 

57. The system of claim 55, wherein the portion of the collection of shared 
document bookmarks is uploaded to the database from the user terminal on demand. 

58. The system of claim 55, wherein a user command received by the second 
portion is transmitted from the user terminal to the database for processing. 

59. The system of claim 58, wherein the portion of the collection of shared 
document bookmarks is uploaded to the database from the user terminal together with the 
user command. 

60. The system of claim 51, wherein the software adapted to maintain the 
collection of shared document bookmarks is also adapted to maintain a plurality of .user- 
specific document bookmark sets corresponding to the plurality of users. 

61. The system of claim 60, wherein the software is adapted to publish a 
bookmark from a user-specific document bookmark set to the collection of shared 
document bookmarks upon request by a user. 
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62. The system of claim 51, wherein the collection of shared document 
bookmarks comprises a plurality of shared bookmarks arranged in a global hierarchy of 
categories. 

5 63. The system of claim 53, wherein the first portion is adapted to monitor the 

availability of each shared document bookmark in the collection of shared document 
bookmarks. 

64. The system of claim 63, wherein if a shared document bookmark is 
10 unavailable, the first portion is adapted to generate a recommendation for a similar 

document chosen from the collection of shared document bookmarks. 

65. A method for generating a recommendation from a collection of shared 
document bookmarks contributed by a plurality of users, wherein each shared document 

15 bookmark represents a document, comprising the steps of: 
identifying at least one unavailable bookmark; 

searching at least a portion of the collection of shared document bookmarks; and 
retrieving a group of bookmarks that match the unavailable bookmark. 
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(57) Abstract: A search and recommendation system employs the prefer- 
ences and profiles of individual users and groups within a community of 
users, as well as information derived from shared document bookmarks, 
to augment Internet searches, re-rank search results, and provide recom- 
mendations for documents based on a subject-matter query. The search 
and recommendation system operates in the context of a shared bookmark 
manager, which stores individual users' bookmarks (some of which may 
be published or shared for group use) on a centralized bookmark database 
connected to the Internet. The shared bookmark manager is implemented 
as a distributed program, portions of which operate on users' terminals and 
other portions of which operate on the centralized bookmark database. 
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